InvertPermutation
计算输入排列的逆排列。对于输入数组 input,输出数组 output 满足:
\[output[input_i] = i
\quad \text{for } i = 0, 1, \dots, num-1\]
- 输入:
input - 输入排列数组地址。
num - 数组长度。
core_mask - 核掩码(仅适用于共享存储版本)。
- 输出:
output - 逆排列数组地址,长度同输入。
- 支持平台:
FT78NEMT7004
备注
FT78NE 支持int8, int16, int32
MT7004 支持int16, int32
共享存储版本:
-
void i8_invertpermutation_s(int8_t *input, int8_t *output, int num, int core_mask)
-
void i16_invertpermutation_s(int16_t *input, int16_t *output, int num, int core_mask)
-
void i32_invertpermutation_s(int32_t *input, int32_t *output, int num, int core_mask)
C调用示例:
1//FT78NE示例
2#include <stdio.h>
3#include <invertpermutation.h>
4
5int main() {
6 int32_t *input = (int32_t *)0xA0000000; // input在DDR空间
7 int32_t *output = (int32_t *)0xC0000000;
8 int num = 100;
9 int core_mask = 0xff;
10
11 i32_invertpermutation_s(input, output, num, core_mask);
12 return 0;
13}
私有存储版本:
-
void i8_invertpermutation_p(int8_t *input, int8_t *output, int num)
-
void i16_invertpermutation_p(int16_t *input, int16_t *output, int num)
-
void i32_invertpermutation_p(int32_t *input, int32_t *output, int num)
C调用示例:
1//FT78NE示例
2#include <stdio.h>
3#include <invertpermutation.h>
4
5int main() {
6 int32_t *input = (int32_t *)0x10810000; // input在L2空间
7 int32_t *output = (int32_t *)0x10820000;
8 int num = 100;
9
10 i32_invertpermutation_p(input, output, num);
11 return 0;
12}